package com.zhugang.week04;

/**
 * @program algorithms
 * @description: bubbleSort
 * @author: chanzhugang
 * @create: 2022/06/15 22:12
 */
public class BubbleSort {

    /**
     * 冒泡排序
     *
     * @param a
     * @param n
     */
    public void bubbleSort(int[] a, int n) {
        /**
         * 比较相邻元素的大小，交换位置
         */
        for (int i = 0; i < n; i++) {
            // 优化：已经排序好了，退出外层循环
            boolean flag = false;
            for (int j = 0; j < n - i - 1; j++) {
                if (a[j] > a[j + 1]) {
                    // 交换
                    int temp = a[j];
                    a[j] = a[j + 1];
                    a[j + 1] = temp;

                    flag = true;
                }
            }
            // 没有数据交换，提前退出循环
            if (!flag) break;
        }
    }
}